草庐IT

sql - 规范化这个表?

全部标签

ruby - 你会如何用 Ruby 和/或 Haskell 编写这个 Clojure 片段?

我当时正在研究一个Rails模板,并试图编写一些代码,让我可以填充一个表或多列ul标签“从上到下”和“从左到右”,无论多少我指定的列。我刚刚掌握了Ruby的窍门,所以我无法弄清楚这一点。我也很好奇这个有用片段的惯用Haskell版本。感谢对Clojure版本的改进:(defntable[xs&{:keys[colsdirection]:or{cols1direction'right}}](into[](condp=direction'down(let[c(countxs)q(int(/ccols))n(if(>(modcq)0)(incq)q)](applymapvector(part

ruby-on-rails - 关于这个 Rails 关联案例中的 "<<"运算符

我是RubyonRails的新手。在Rails应用程序中,我看到了如下代码:在模型中,有一个类Car:classCar在controller中,有一个方法“some_method”classCarsController我有三个问题要问:1.在Controller的代码中@my_car.components,它有什么作用?什么是什么意思?2.“3.是否Car类必须显式定义has_many关联Componentclassif""isused或者是""可用于向Car添加新关联,即使关联未在Car中定义显式类? 最佳答案 编辑后:第1点@m

ruby - 这个 ruby 迭代器棘手的干净解决方案?

k=[1,2,3,4,5]forninkputsnifn==2k.delete(n)endendputsk.join(",")#Result:#1#2#4#5#[1,3,4,5]#Desired:#1#2#3#4#5#[1,3,4,5]同样的效果发生在另一个数组迭代器k.each上:k=[1,2,3,4,5]k.eachdo|n|putsnifn==2k.delete(n)endendputsk.join(",")具有相同的输出。发生这种情况的原因很清楚......Ruby实际上并没有遍历存储在数组中的对象,而是只是将它变成一个漂亮的数组索引迭代器,从索引0开始,每次增加索引直到结束。

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby-on-rails - 帮助重构这个讨厌的 Ruby if/else 语句

所以我有这个大而多毛的if/else语句。我将一个跟踪号传递给它,然后它确定它是什么类型的跟踪号。我怎样才能简化这件事?特别想减少代码行数。ifnum_length是的,我知道。这很讨厌。 最佳答案 试试这个。我使用case和正则表达式重写了它。我还使用:symbols而不是"strings"作为返回值,但您可以将其改回。tracking_service=casenumberwhen/^.Z/then:upswhen/^Q/then:dhlwhen/^96.{20}$/then:fedexwhen/^[HK].{10}$/then:

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按

ruby - 这个 Ruby 语法是什么?

我刚看了下面的代码:classDirdefself.create_uniq&b###Here,&shouldmeanbisablocku=0loopdobeginfn=b[u]###But,whatdoesb[u]mean?Andbisnotcalled.FileUtils.mkdirfnreturnfnrescueErrno::EEXISTu+=1endendioendend我把我的困惑作为代码中的注释。 最佳答案 在末尾使用&b定义方法允许您使用传递给方法的block作为Proc对象。现在,如果您有Proc实例,[]语法是cal

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G